



Fig. 1

10033446 • 122701

Branch is approved

|         | Cycle 1 | Cycle 2 | Cycle 3 | Cycle 4 |  |
|---------|---------|---------|---------|---------|--|
| IF      | ①       | ②       | ③       | ④       |  |
| DEC     | ⑤       | ⑥       | ⑦       | ⑧       |  |
| EX      |         | ⑨       | ⑩       | ⑪       |  |
| ME      |         |         |         |         |  |
| WB      |         |         |         |         |  |
| Op code |         |         | ⑫       |         |  |
| Operand |         |         |         |         |  |

- ① Branch
- ② Branch designation
- ③ Branch designation +4
- ④ Branch designation +8
- ⑤ Execution
- ⑥ Branch
- ⑦ Branch designation
- ⑧ Branch designation +4
- ⑨ Execution
- ⑩ Branch
- ⑪ Branch designation
- ⑫ Fetch part 103

Fig. 2 A

Branch is not approved

|         | Cycle 1 | Cycle 2 | Cycle 3 | Cycle 4 |   |
|---------|---------|---------|---------|---------|---|
| IF      | ①       | ②       | ③       |         |   |
| DEC     | ④       | ⑤       |         |         |   |
| EX      |         | ⑥       | ⑦       | ⑧       |   |
| ME      |         |         |         |         |   |
| WB      |         |         |         |         |   |
| Op code |         | ⑨       |         | ⑩       | ⑪ |
| Operand |         | ⑫       |         | ⑬       | ⑭ |

- ① Branch
- ② Branch designation
- ③ Next of branch instruction
- ④ Execution
- ⑤ Branch
- ⑥ Execution
- ⑦ Branch
- ⑧ Next of branch instruction
- ⑨ Fetch part 103
- ⑩ Dedicated register
- ⑪ Fetch part 102
- ⑫ Fetch part 103
- ⑬ Memory
- ⑭ Fetch part 102

Fig. 2 B



Fig. 3



Fig. 4

10033445 - 122701

Branch is approved



Fig. 5 A

Branch is not approved



Fig. 5 B



Fig. 6

10033446.122701

| Example of case statement | Assembler description | Converted result of instruction sequence |
|---------------------------|-----------------------|------------------------------------------|
| switch(mode)              | ld d0,(mode)          | ld d0,(mode)                             |
| case: 1 a=b+1;            | cmp d0,1              | cmp d0,1                                 |
| case: 3 a=c;              | jz                    | cjz                                      |
| case: 5 a=b+c;            | cmp d0,3              | cmp d0,3                                 |
| :                         | jz                    | cjz                                      |
| :                         | cmp d0,5              | cmp d0,5                                 |
|                           | jz                    | cjz                                      |
|                           | :                     | :                                        |
|                           | :                     | :                                        |

Fig. 7A

Fig. 7B

Fig. 7C

100033445 - 122704

Branch is approved



Fig. 8 A

Branch is not approved



Fig. 8 B

Branch is approved



Fig. 9 A

Branch is not approved



Fig. 9 B



Fig. 10

| Example of<br>case statement | Assembler<br>description                                                      | Converted result of<br>instruction sequence                                    |
|------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| switch(mode)                 | ld d0,(mode)                                                                  | ld d0,(mode)                                                                   |
| case: 1 a=b+1;               | cmp d0,1                                                                      | cmp d0,1                                                                       |
| case: 3 a=c;                 | jnz A                                                                         | cjnz A                                                                         |
| case: 5 a=b+c;               | ld d0,(b)                                                                     | ld d0,(b)                                                                      |
| :                            | add d0,1                                                                      | add d0,1                                                                       |
| :                            | st d0,(a)                                                                     | st d0,(a)                                                                      |
|                              | jmp END                                                                       | jmp END                                                                        |
| Fig. 11A                     | A: cmp d0,3<br>jnz B<br>ld d0,(c)<br>st d0,(a)<br>jmp END                     | A: cmp d0,3<br>cjnz B<br>ld d0,(c)<br>st d0,(a)<br>jmp END                     |
|                              | B: cmp d0,5<br>jnz C<br>ld d0,(c)<br>ld d1,(b)<br>add d0,d1<br>st d0,(a)<br>: | B: cmp d0,5<br>cjnz C<br>ld d0,(c)<br>ld d1,(b)<br>add d0,d1<br>st d0,(a)<br>: |
|                              | END:                                                                          | END:                                                                           |

Fig. 11B

Fig. 11C



Fig. 12

10033446.122701

Unconditional branch



Fig. 13

10033446.122701



Fig. 14

10033446 - 122701

Unconditional branch



Fig. 15

10033446 - 122701



Fig. 16

10033446 • 122701

Example of case statement

```
switch(mode1){  
    case: 1 a1=b1+1;  
    case: 3 a1=c1;  
    case: 5 a1=b1+c1;  
}  
switch(mode2){  
    case: 1 a2=b2+1;  
    case: 3 a2=c2;  
    case: 5 a2=b2+c2;  
}
```

Fig. 17

### Assembler description

|               |     |               |
|---------------|-----|---------------|
| ld d0,(mode1) | C1  | ld d0,(mode2) |
| cmp d0,1      |     | cmp d0,1      |
| jnz A1        |     | jnz A2        |
| ld d0,(b)     |     | ld d0,(b)     |
| add d0,1      |     | add d0,1      |
| st d0,(a)     |     | st d0,(a)     |
| jmp C1        |     | jmp C2        |
| A1: cmp d0,3  | A1: | cmp d0,3      |
| jnz B1        |     | jnz B2        |
| ld d0,(c)     |     | ld d0,(c)     |
| st d0,(a)     |     | st d0,(a)     |
| jmp C1        |     | jmp C2        |
| B1: cmp d0,5  | B1: | cmp d0,5      |
| jnz C1        |     | jnz C2        |
| ld d0,(c)     |     | ld d0,(c)     |
| ld d1,(b)     |     | ld d1,(b)     |
| add d0,d1     |     | add d0,d1     |
| st d0,(a)     |     | st d0,(a)     |
| C2: . . .     |     | . . .         |

Fig. 18

Instruction sequence after conversion

|               |     |               |
|---------------|-----|---------------|
| ld d0,(mode1) | C1  | ld d0,(mode2) |
| cmp d0,1      |     | cmp d0,1      |
| cjnz A1       |     | cjnz A2       |
| ld d0,(b)     |     | ld d0,(b)     |
| add d0,1      |     | add d0,1      |
| st d0,(a)     |     | st d0,(a)     |
| cjmp C1       |     | cjmp C2       |
| A1: cmp d0,3  | A1: | cmp d0,3      |
| cjnz B1       |     | cjnz B2       |
| ld d0,(c)     |     | ld d0,(c)     |
| st d0,(a)     |     | st d0,(a)     |
| cjmp C1       |     | cjmp C2       |
| B1: cmp d0,5  | B1: | cmp d0,5      |
| cjnz C1       |     | cjnz C2       |
| ld d0,(c)     |     | ld d0,(c)     |
| ld d1,(b)     |     | ld d1,(b)     |
| add d0,d1     |     | add d0,d1     |
| st d0,(a)     |     | st d0,(a)     |
| C2: . . .     |     | . . .         |

Fig. 19

Branch is approved



Fig. 20 A PRIOR ART

Branch is not approved



Fig. 20 B PRIOR ART

100133446 - 122701

Branch is approved

|     | Cycle 1 | Cycle 2 | Cycle 3 | Cycle 4 |
|-----|---------|---------|---------|---------|
| IF  | ①       | ②       | ③       |         |
| DEC | ④       | ⑤       | ⑥       | ⑦       |
| EX  |         | ⑧       | ⑨       | ⑩       |
| ME  |         |         |         |         |
| WB  |         |         |         |         |

① Branch  
② Delayed slot  
③ Branch designation  
④ Execution  
⑤ Branch  
⑥ Delayed slot  
⑦ Branch designation  
⑧ Execution  
⑨ Branch  
⑩ Delayed slot

Fig. 21 A PRIOR ART

Branch is not approved

|     | Cycle 1 | Cycle 2 | Cycle 3 | Cycle 4 |
|-----|---------|---------|---------|---------|
| IF  | ①       | ②       | ③       |         |
| DEC | ④       | ⑤       | ⑥       | ⑦       |
| EX  |         | ⑧       | ⑨       | ⑩       |
| ME  |         |         |         |         |
| WB  |         |         |         |         |

① Branch  
② Delayed slot  
③ Next of branch instruction  
④ Execution  
⑤ Branch  
⑥ Delayed slot  
⑦ Next of branch instruction  
⑧ Execution  
⑨ Branch  
⑩ Delayed slot

Fig. 21 B PRIOR ART

10033446.132701

Example of  
case statement

```
switch(mode)
case: 1 a=b+1;
case: 3 a=c;
case: 5 a=b+c;
:
:
```

Assembler  
description

```
ld d0,(mode)
cmp d0,1
jz
cmp d0,3
jz
cmp d0,5
jz
:
:
```

Fig. 22A

PRIOR ART

Fig. 22B

PRIOR ART